<template>
  <div>
    <!-- 添加按钮 -->
    <el-button style="margin-top:20px" type="primary" icon="el-icon-plus">添加</el-button>

    <!-- 表格
      border 用于让整个table表格添加边框
      el-table 组件用于生成整个表格
      el-table-column 组件用于生成表格中的每一列
      label 用于确认表头标题
      width 用于指定当前列宽度，如果没有写，就会将剩余宽度与其它没写的column进行平分
      align 用于将当前列中的内容居中
     -->
    <!-- 通过el-table属性添加标签属性data,可以将需要遍历的数组交给el-table组件
          el-table 会将当前data的数组交给每一个 el-table-column组件，组件内部会自动进行v-for遍历
          给每个el-table-column组件添加 prop 标签属性，声明当前列需要展示遍历对象中的哪个属性结果
          注意：prop执行的内容，在elementUI中默认作为文本显示
      -->
    <el-table :data="trademarkList" border style="width: 100%; margin:20px 0;">
      <el-table-column label="序号" type="index" width="80" align="center" />
      <el-table-column label="品牌名称" prop="tmName" />
      <el-table-column label="品牌LOGO">
        <!-- 作用域插槽
          想要自定义列显示内容，需要用到作用域插槽，给column列组建传入 template 结构
         -->
        <template slot-scope="{row}">
          <img :src="row.logoUrl" alt="" style="width:100px;height:80px">
        </template>
      </el-table-column>
      <el-table-column label="操作">
        <el-button type="info" size="mini" icon="el-icon-edit">编辑</el-button>
        <el-button type="danger" size="mini" icon="el-icon-delete">删除</el-button>
      </el-table-column>
    </el-table>

    <!-- 分页器

        相关属性
        current-page  指定当前所在页数
        page-sizes 指定页面显示数量下拉框的选项
        page-size 指定当前页面显示条数
        layout 用来控制当前分页器组件内的组成结构和顺序
        total 指定总页数
     -->
    <el-pagination
      style="text-align:center"
      :current-page="page"
      :page-sizes="[2, 3, 10]"
      :page-size="limit"
      layout="prev, pager, next, jumper, ->, sizes, total"
      :total="total"
      @current-change="handleCurrentChange"
      @size-change="handleSizeChange"
    />

    <!-- 对话框
      标签属性：
      dialogFormVisible 用于控制当前 dialog 组件的显示隐藏
      :model="form" 用来收集表单数据的对象交给 form 表单
      label-width="number" 用来控制表单的label的宽度

      组件用处
      el-dialog 用于显示遮罩层，同时显示对话框
      el-form 主要功能，用于收集用户输入的表单数据
      el-form-item 每一个form-item代表form表单的一行

      注意：尽量把tmForm的内部结构处理成接口需要的结构
     -->
    <el-dialog title="添加品牌" style="width:80%;" :visible.sync="dialogFormVisible">
      <el-form :model="tmForm">
        <el-form-item label="品牌名称" label-width="100px">
          <el-input v-model="tmForm.name" autocomplete="off" />
        </el-form-item>
        <el-form-item label="品牌LOGO" label-width="100px">
          <!-- 用户头像上传 -->
          <el-upload
            class="avatar-uploader"
            action="https://jsonplaceholder.typicode.com/posts/"
            :show-file-list="false"
            :on-success="handleAvatarSuccess"
            :before-upload="beforeAvatarUpload"
          >
            <img v-if="imageUrl" :src="imageUrl" class="avatar">
            <i v-else class="el-icon-plus avatar-uploader-icon" />
            <div slot="tip" class="el-upload__tip">只能上传jpg/png文件，且不超过500kb</div>
          </el-upload>
        </el-form-item>
      </el-form>
      <div slot="footer" class="dialog-footer">
        <el-button @click="dialogFormVisible = false">取 消</el-button>
        <el-button type="primary" @click="dialogFormVisible = false">确 定</el-button>
      </div>
    </el-dialog>
  </div>
</template>

<script>
export default {
  name: 'TradeMark',
  data() {
    return {
      // 分页数据
      page: 1,
      limit: 3,
      total: 15,
      // 品牌列表数据
      trademarkList: [],
      // 对话框
      dialogFormVisible: true,
      tmForm: {
        tmName: ''
      },
      // 图片上传
      imageUrl: '' // 不管用不用，先复制过来
    }
  },
  mounted() {
    this.getTradeMarkList()
  },
  methods: {
    // 获取品牌列表
    async getTradeMarkList() {
      // const result = await this.$API.trademark.getTradeMarkList(this.page, this.limit)
      // console.log(result)

      // 使用解构赋值
      const { data: { total, records }} = await this.$API.trademark.getTradeMarkList(this.page, this.limit)
      // 以上解构赋值相当于：const total = result.data.total
      this.total = total
      this.trademarkList = records
    },
    // 处理分页
    handleCurrentChange(value) {
      // 通过当前事件，可以知道用户点击哪个页数
      // console.log('handleCurrentChange', value)
      this.page = value

      // 发送请求，获取对应页面的数据
      this.getTradeMarkList()
    },
    handleSizeChange(value) {
      // 通过当前事件，可以知道用户点击了哪个条数选择器项
      // console.log('handleSizeChange', value)
      this.limit = value

      // 发送请求，获取对应页面的数据
      this.getTradeMarkList()
    },
    // 图片上传
    handleAvatarSuccess(res, file) {
      this.imageUrl = URL.createObjectURL(file.raw)
    },
    beforeAvatarUpload(file) {
      const isJPG = file.type === 'image/jpeg'
      const isLt2M = file.size / 1024 / 1024 < 2

      if (!isJPG) {
        this.$message.error('上传头像图片只能是 JPG 格式!')
      }
      if (!isLt2M) {
        this.$message.error('上传头像图片大小不能超过 2MB!')
      }
      return isJPG && isLt2M
    }
  }
}
</script>

<style>
 .avatar-uploader .el-upload {
    border: 1px dashed #d9d9d9;
    border-radius: 6px;
    cursor: pointer;
    position: relative;
    overflow: hidden;
  }
  .avatar-uploader .el-upload:hover {
    border-color: #409EFF;
  }
  .avatar-uploader-icon {
    font-size: 28px;
    color: #8c939d;
    width: 178px;
    height: 178px;
    line-height: 178px;
    text-align: center;
  }
  .avatar {
    width: 178px;
    height: 178px;
    display: block;
  }
</style>
